PowerShell এবং Networking Commands

Microsoft Technologies - মাইক্রোসফট পাওয়ারশেল (Powershell)
197
197

PowerShell একটি শক্তিশালী টুল যা নেটওয়ার্ক ম্যানেজমেন্ট, নেটওয়ার্ক টেস্টিং, এবং নেটওয়ার্ক কনফিগারেশন কাজে ব্যবহৃত হয়। PowerShell-এর বিভিন্ন কমান্ড দিয়ে আপনি নেটওয়ার্কিং সম্পর্কিত কাজ সহজে এবং দক্ষভাবে সম্পন্ন করতে পারেন। এই কমান্ডগুলো ব্যবহার করে আপনি নেটওয়ার্ক সংক্রান্ত নানা তথ্য জানার পাশাপাশি নেটওয়ার্ক ডিভাইস কনফিগারও করতে পারেন।


PowerShell Networking Commands

PowerShell-এ নেটওয়ার্কিং সম্পর্কিত কাজের জন্য বেশ কিছু কমান্ড রয়েছে যা আপনাকে নেটওয়ার্ক অ্যাডাপ্টার, কনফিগারেশন, সংযোগ এবং অন্যান্য নেটওয়ার্ক সম্পর্কিত কার্যক্রম পরিচালনা করতে সাহায্য করবে।

1. Get-NetAdapter

এই কমান্ডটি নেটওয়ার্ক অ্যাডাপ্টার সম্পর্কিত তথ্য দেখাবে, যেমন অ্যাডাপ্টারের স্টেট, ড্রাইভার ইত্যাদি।

Get-NetAdapter

এটি আপনার সিস্টেমে ইনস্টল করা সমস্ত নেটওয়ার্ক অ্যাডাপ্টারের তালিকা প্রদর্শন করবে, তার স্টেট (অ্যাকটিভ বা ইনঅ্যাকটিভ), MAC ঠিকানা, প্রকার (ইথারনেট বা Wi-Fi) ইত্যাদি।

2. Set-NetAdapter

এই কমান্ডের মাধ্যমে আপনি একটি নির্দিষ্ট নেটওয়ার্ক অ্যাডাপ্টারের কনফিগারেশন পরিবর্তন করতে পারেন, যেমন ডিভাইসটি ডিসেবল বা এনেবল করা।

Set-NetAdapter -Name "Ethernet" -Enabled $false

এটি Ethernet নামের অ্যাডাপ্টারটি ডিসেবল করবে। আপনি -Enabled $true ব্যবহার করে আবার এটি এনেবল করতে পারেন।

3. Get-NetIPAddress

আপনার সিস্টেমের IP ঠিকানা, সাবনেট মাস্ক এবং গেটওয়ে জানার জন্য এই কমান্ড ব্যবহার করা হয়।

Get-NetIPAddress

এটি সমস্ত নেটওয়ার্ক অ্যাডাপ্টারের জন্য IP ঠিকানা এবং সংশ্লিষ্ট তথ্য প্রদর্শন করবে।

4. Test-Connection

এই কমান্ডটি পিং (ping) টেস্টের মতো কাজ করে এবং আপনি নেটওয়ার্কের সংযোগ পরীক্ষা করতে পারেন। এটি একটি হোস্টের সাথে যোগাযোগ স্থাপন করতে ব্যবহৃত হয়।

Test-Connection -ComputerName www.google.com

এটি www.google.com-এ পিং পাঠাবে এবং যোগাযোগ স্থাপিত হচ্ছে কিনা তা পরীক্ষা করবে।

5. Test-NetConnection

Test-NetConnection একটি উন্নত কমান্ড যা বিভিন্ন নেটওয়ার্ক টেস্টের জন্য ব্যবহার করা হয়। এটি পোর্ট চেক, DNS চেক এবং TCP/IP টেস্টও করতে সক্ষম।

Test-NetConnection -ComputerName www.google.com -Port 80

এটি পরীক্ষা করবে যে, www.google.com-এর 80 নম্বর পোর্টে সংযোগ স্থাপন করা যাচ্ছে কি না।

6. Get-NetRoute

এই কমান্ডটি সিস্টেমের রুট টেবিলের তথ্য প্রদান করে। এটি গেটওয়ে, সাবনেট, এবং অন্যান্য রুট সম্পর্কিত তথ্য দেখায়।

Get-NetRoute

এটি আপনার সিস্টেমের গেটওয়ে, সাবনেট মাস্ক এবং রুটিং টেবিলের তথ্য দেখাবে।

7. New-NetIPAddress

এই কমান্ডটি নতুন IP ঠিকানা কনফিগার করতে ব্যবহৃত হয়। আপনি যদি স্ট্যাটিক IP সেট করতে চান, তবে এটি ব্যবহার করতে পারেন।

New-NetIPAddress -InterfaceAlias "Ethernet" -IPAddress 192.168.1.100 -PrefixLength 24 -DefaultGateway 192.168.1.1

এটি Ethernet ইন্টারফেসে 192.168.1.100 ঠিকানা এবং 192.168.1.1 গেটওয়ে সেট করবে।

8. Get-NetDNSConfiguration

এই কমান্ডটি DNS কনফিগারেশন সম্পর্কিত তথ্য দেখায়, যেমন DNS সার্ভার, DNS সার্ভার অ্যাড্রেস ইত্যাদি।

Get-NetDNSConfiguration

এটি DNS সার্ভার এবং আপনার সিস্টেমের DNS কনফিগারেশন দেখাবে।

9. Get-NetFirewallRule

এই কমান্ডটি ফায়ারওয়াল রুল সম্পর্কিত তথ্য দেখতে ব্যবহৃত হয়। এটি ফায়ারওয়াল নীতিমালা এবং তার স্টেট প্রদর্শন করবে।

Get-NetFirewallRule

এটি আপনার সিস্টেমে কনফিগার করা সমস্ত ফায়ারওয়াল রুলের তালিকা দেখাবে।

10. Set-DNSClientServerAddress

এই কমান্ডটি DNS সার্ভারের ঠিকানা পরিবর্তন করতে ব্যবহার করা হয়।

Set-DNSClientServerAddress -InterfaceAlias "Ethernet" -ServerAddresses 8.8.8.8, 8.8.4.4

এটি Ethernet ইন্টারফেসের জন্য DNS সার্ভার হিসেবে গুগলের DNS সার্ভার (8.8.8.8 এবং 8.8.4.4) সেট করবে।


PowerShell-এ Advanced Networking Operations

1. Enable/Disable Network Adapter

আপনি যদি একটি নেটওয়ার্ক অ্যাডাপ্টারকে ডিসেবল বা এনেবল করতে চান, তাহলে Enable-NetAdapter এবং Disable-NetAdapter কমান্ড ব্যবহার করতে পারেন।

Disable-NetAdapter -Name "Wi-Fi" -Confirm:$false

এটি Wi-Fi অ্যাডাপ্টারটি ডিসেবল করবে।

2. Configure a Static IP Address

যদি আপনি একটি সিস্টেমের জন্য স্ট্যাটিক IP ঠিকানা কনফিগার করতে চান, নিচের কমান্ডটি ব্যবহার করতে পারেন:

New-NetIPAddress -InterfaceAlias "Ethernet" -IPAddress 192.168.1.100 -PrefixLength 24 -DefaultGateway 192.168.1.1

এটি Ethernet ইন্টারফেসে 192.168.1.100 IP ঠিকানা এবং 192.168.1.1 গেটওয়ে সেট করবে।

3. Configure DNS Server

DNS সার্ভার কনফিগার করতে:

Set-DNSClientServerAddress -InterfaceAlias "Ethernet" -ServerAddresses 8.8.8.8

এটি DNS সার্ভার হিসেবে গুগলের DNS সার্ভার 8.8.8.8 সেট করবে।


Networking Troubleshooting with PowerShell

PowerShell দিয়ে নেটওয়ার্ক সমস্যাগুলোর সমাধান সহজে করা যায়। নিচের কমান্ডগুলো ব্যবহার করে আপনি নেটওয়ার্ক সমস্যা চিহ্নিত এবং সমাধান করতে পারবেন:

  1. Ping Test with Test-Connection
Test-Connection -ComputerName www.example.com

এটি নির্দিষ্ট ওয়েবসাইট বা সার্ভারের সাথে পিং পাঠাবে।

  1. Port Checking
Test-NetConnection -ComputerName www.example.com -Port 443

এটি চেক করবে যে, নির্দিষ্ট পোর্ট (যেমন HTTPS পোর্ট 443) খোলা আছে কিনা।

  1. Traceroute (Hop-by-hop network route tracing)
Test-NetConnection -Traceroute -ComputerName www.example.com

এটি একটি ট্রেসরুট টেস্ট করে, যে পথে নেটওয়ার্ক প্যাকেটগুলি যাত্রা করছে তা দেখাবে।


PowerShell-এর নেটওয়ার্কিং কমান্ডগুলো খুবই শক্তিশালী এবং সিস্টেম অ্যাডমিনিস্ট্রেটরদের জন্য এটি একটি অপরিহার্য টুল।

Content added By

Network Information Fetch করা (Test-Connection, Get-NetIPAddress)

132
132

PowerShell আপনাকে সিস্টেমের নেটওয়ার্ক সম্পর্কিত তথ্য সংগ্রহ করার জন্য শক্তিশালী কমান্ড এবং cmdlet প্রদান করে। এগুলি দিয়ে আপনি নেটওয়ার্ক অ্যাডাপ্টার, আইপি ঠিকানা, DNS সার্ভার, গেটওয়ে, পিং টেস্ট এবং অন্যান্য নেটওয়ার্ক ডিটেইলস সহজেই দেখতে পারেন।


Test-Connection কমান্ড

Test-Connection হল একটি PowerShell কমান্ড যা পিং (Ping) পরীক্ষা চালানোর জন্য ব্যবহৃত হয়। এটি একটি সিস্টেমের সাথে সংযোগ পরীক্ষা করে, এর মাধ্যমে আপনি দেখতে পারেন যে, কোনো নির্দিষ্ট হোস্ট বা আইপি ঠিকানার সাথে নেটওয়ার্ক সংযোগ রয়েছে কিনা। Test-Connection কমান্ডটি Windows এর ping কমান্ডের মতোই কাজ করে, তবে এটি আরো শক্তিশালী এবং কাস্টমাইজেবল।

উদাহরণ ১: পিং টেস্ট করা

Test-Connection -ComputerName google.com

এটি google.com এর সাথে সংযোগ পরীক্ষা করবে এবং এর ফলাফল দেখাবে, যেমন প্যাকেট লস, রাউন্ড ট্রিপ টাইম ইত্যাদি।

উদাহরণ ২: নির্দিষ্ট আইপি ঠিকানায় পিং টেস্ট করা

Test-Connection -ComputerName 192.168.1.1

এটি 192.168.1.1 আইপি ঠিকানার সাথে পিং টেস্ট করবে এবং প্যাকেটের প্রেরণ এবং গ্রহণ সময় দেখাবে।

উদাহরণ ৩: পিং টেস্টের কাস্টম প্যারামিটার ব্যবহার

আপনি পিং টেস্টের কিছু অতিরিক্ত প্যারামিটার ব্যবহার করতে পারেন যেমন প্যাকেট সংখ্যা, টাইমআউট, ইত্যাদি। উদাহরণস্বরূপ:

Test-Connection -ComputerName google.com -Count 5 -TimeoutSeconds 2

এটি ৫টি প্যাকেট পাঠাবে এবং প্রতি প্যাকেটের জন্য ২ সেকেন্ড টাইমআউট ব্যবহার করবে।


Get-NetIPAddress কমান্ড

Get-NetIPAddress কমান্ডটি নেটওয়ার্ক অ্যাডাপ্টারের আইপি ঠিকানা এবং অন্যান্য নেটওয়ার্ক কনফিগারেশন তথ্য সংগ্রহ করতে ব্যবহৃত হয়। এটি এক বা একাধিক নেটওয়ার্ক অ্যাডাপ্টারের বিস্তারিত তথ্য প্রদান করে, যেমন আইপি ঠিকানা, সাবনেট মাস্ক, গেটওয়ে ইত্যাদি।

উদাহরণ ১: সমস্ত নেটওয়ার্ক অ্যাডাপ্টারের আইপি ঠিকানা দেখতে

Get-NetIPAddress

এটি আপনার সিস্টেমে কনফিগার করা সমস্ত নেটওয়ার্ক অ্যাডাপ্টারের আইপি ঠিকানা, সাবনেট মাস্ক, গেটওয়ে ইত্যাদি দেখাবে।

উদাহরণ ২: নির্দিষ্ট নেটওয়ার্ক অ্যাডাপ্টারের আইপি ঠিকানা দেখতে

আপনি নির্দিষ্ট নেটওয়ার্ক অ্যাডাপ্টারের আইপি ঠিকানা দেখতে এই কমান্ড ব্যবহার করতে পারেন:

Get-NetIPAddress -InterfaceAlias "Ethernet"

এটি "Ethernet" নামে যে অ্যাডাপ্টারটি রয়েছে তার আইপি ঠিকানা এবং অন্যান্য নেটওয়ার্ক তথ্য দেখাবে।

উদাহরণ ৩: IPv4 বা IPv6 আইপি ঠিকানা দেখানো

যদি আপনি কেবল IPv4 বা IPv6 ঠিকানা দেখতে চান, তবে আপনি ফিল্টার করে এই কমান্ডটি চালাতে পারেন:

Get-NetIPAddress -AddressFamily IPv4

এটি কেবল IPv4 ঠিকানা দেখাবে।


Get-NetIPConfiguration কমান্ড

Get-NetIPConfiguration কমান্ডটি আপনার সিস্টেমের নেটওয়ার্ক কনফিগারেশন সংক্রান্ত তথ্য প্রদান করে। এটি আইপি ঠিকানা, সাবনেট মাস্ক, গেটওয়ে, DNS সার্ভারের তথ্য দেখায়।

উদাহরণ ১: সিস্টেমের সমস্ত নেটওয়ার্ক কনফিগারেশন দেখতে

Get-NetIPConfiguration

এটি সিস্টেমের সমস্ত নেটওয়ার্ক অ্যাডাপ্টারের কনফিগারেশন তথ্য দেখাবে।

উদাহরণ ২: নির্দিষ্ট নেটওয়ার্ক অ্যাডাপ্টারের কনফিগারেশন দেখতে

Get-NetIPConfiguration -InterfaceAlias "Wi-Fi"

এটি "Wi-Fi" নামক নেটওয়ার্ক অ্যাডাপ্টারের আইপি কনফিগারেশন তথ্য দেখাবে।


Get-NetRoute কমান্ড

Get-NetRoute কমান্ডটি আপনার সিস্টেমের রাউটিং টেবিলের তথ্য সংগ্রহ করতে ব্যবহৃত হয়। এটি ডিফল্ট গেটওয়ে, রাউটিং পাথ এবং নেটওয়ার্কের অন্যান্য রাউটিং কনফিগারেশন দেখাতে সক্ষম।

উদাহরণ ১: রাউটিং টেবিল দেখানো

Get-NetRoute

এটি আপনার সিস্টেমের সমস্ত রাউটিং টেবিল এবং তাদের কনফিগারেশন প্রদর্শন করবে।

উদাহরণ ২: ডিফল্ট গেটওয়ে দেখানো

Get-NetRoute -DestinationPrefix "0.0.0.0/0"

এটি আপনার ডিফল্ট গেটওয়ে দেখাবে, যা সাধারণত ইন্টারনেট বা অন্যান্য নেটওয়ার্কের সাথে সংযোগ স্থাপন করতে ব্যবহৃত হয়।


NPM (Network Performance Monitor) এবং পিং টেস্ট

PowerShell-এ নেটওয়ার্ক পারফরম্যান্স মনিটর এবং পিং টেস্টের জন্য আরো কাস্টম স্ক্রিপ্ট তৈরি করা সম্ভব। আপনি Test-Connection কমান্ড ব্যবহার করে একটি স্ক্রিপ্ট তৈরি করতে পারেন, যা নির্দিষ্ট সময় পর পর পিং টেস্ট চালিয়ে রিপোর্ট তৈরি করবে।

উদাহরণ ১: নির্দিষ্ট সময় পর পর পিং টেস্ট চালানো

while ($true) {
    Test-Connection -ComputerName google.com -Count 1
    Start-Sleep -Seconds 5
}

এই স্ক্রিপ্টটি প্রতি ৫ সেকেন্ড পর পর google.com এর সাথে পিং টেস্ট করবে এবং তার ফলাফল দেখাবে।


সারাংশ

PowerShell দিয়ে নেটওয়ার্ক সম্পর্কিত তথ্য সংগ্রহ করার জন্য Test-Connection, Get-NetIPAddress, Get-NetRoute, এবং Get-NetIPConfiguration কমান্ডগুলি অত্যন্ত কার্যকরী। আপনি এসব কমান্ড ব্যবহার করে নেটওয়ার্ক সংযোগ, আইপি কনফিগারেশন, রাউটিং টেবিল, এবং অন্যান্য নেটওয়ার্ক বিষয়ক তথ্য সহজে পেতে পারেন। PowerShell এর এই ক্ষমতাগুলি নেটওয়ার্ক অ্যাডমিনিস্ট্রেটর এবং টেকনিক্যাল পেশাদারদের জন্য অত্যন্ত সহায়ক।

Content added By

Firewall Configuration এবং Network Adapter Management

124
124

PowerShell-এ Firewall Configuration এবং Network Adapter Management অনেক গুরুত্বপূর্ণ কাজের মধ্যে পড়ে, যেমন নেটওয়ার্ক নিরাপত্তা নিশ্চিত করা এবং নেটওয়ার্ক অ্যাডাপ্টার সেটিংস কনফিগার করা। PowerShell-এ আপনি সহজেই Windows Firewall কনফিগার করতে পারেন এবং নেটওয়ার্ক অ্যাডাপ্টার সংক্রান্ত কাজ যেমন এনাবল/ডিসেবল করা, আইপি অ্যাড্রেস কনফিগারেশন, ইত্যাদি সম্পাদন করতে পারেন।


Firewall Configuration in PowerShell

Windows Firewall এর কনফিগারেশন PowerShell ব্যবহার করে খুবই সহজ এবং কার্যকর। Windows Firewall কনফিগার করতে আপনি Netsh বা New-NetFirewallRule কমান্ড ব্যবহার করতে পারেন।

1. Windows Firewall চালু/বন্ধ করা

# Windows Firewall চালু করা
Set-NetFirewallProfile -Profile Domain,Public,Private -Enabled True

# Windows Firewall বন্ধ করা
Set-NetFirewallProfile -Profile Domain,Public,Private -Enabled False

এটি ডোমেইন, পাবলিক এবং প্রাইভেট প্রোফাইলের জন্য Windows Firewall চালু অথবা বন্ধ করবে।

2. নতুন Firewall Rule তৈরি করা

# TCP পোর্ট 8080 এর জন্য একটি নতুন ইনকামিং ফায়ারওয়াল রুল তৈরি করা
New-NetFirewallRule -DisplayName "Allow TCP 8080" -Direction Inbound -Protocol TCP -LocalPort 8080 -Action Allow

এটি একটি নতুন ইনকামিং ফায়ারওয়াল রুল তৈরি করবে যা TCP পোর্ট 8080 এর জন্য ট্র্যাফিক অনুমোদন করবে।

3. ফায়ারওয়াল রুল মুছে ফেলা

# নির্দিষ্ট ফায়ারওয়াল রুল মুছে ফেলা
Remove-NetFirewallRule -DisplayName "Allow TCP 8080"

এটি "Allow TCP 8080" নামের রুলটি মুছে ফেলবে।

4. ফায়ারওয়াল রুলের তালিকা দেখা

# সমস্ত ফায়ারওয়াল রুল দেখানো
Get-NetFirewallRule

এটি সমস্ত সক্রিয় ফায়ারওয়াল রুলের তালিকা দেখাবে।

5. ফায়ারওয়াল প্রোফাইল কনফিগারেশন চেক করা

# সক্রিয় ফায়ারওয়াল প্রোফাইলের অবস্থা চেক করা
Get-NetFirewallProfile

এটি সমস্ত প্রোফাইলের (ডোমেইন, পাবলিক, প্রাইভেট) ফায়ারওয়াল কনফিগারেশন দেখাবে।


Network Adapter Management in PowerShell

PowerShell-এ Network Adapter Management অনেক শক্তিশালী এবং সহজ উপায়ে সম্পন্ন করা যায়। আপনি নেটওয়ার্ক অ্যাডাপ্টার চালু, বন্ধ, কনফিগার করতে পারেন এবং আইপি অ্যাড্রেস পরিবর্তন করতে পারেন।

1. নেটওয়ার্ক অ্যাডাপ্টার চালু/বন্ধ করা

# নেটওয়ার্ক অ্যাডাপ্টার চালু করা
Enable-NetAdapter -Name "Ethernet"

# নেটওয়ার্ক অ্যাডাপ্টার বন্ধ করা
Disable-NetAdapter -Name "Ethernet"

এটি "Ethernet" নামক নেটওয়ার্ক অ্যাডাপ্টারটি চালু অথবা বন্ধ করবে।

2. নেটওয়ার্ক অ্যাডাপ্টারের তথ্য দেখা

# সমস্ত নেটওয়ার্ক অ্যাডাপ্টারের তথ্য দেখা
Get-NetAdapter

এটি আপনার কম্পিউটারে থাকা সমস্ত নেটওয়ার্ক অ্যাডাপ্টারের তথ্য দেখাবে (যেমন, অ্যাডাপ্টারের নাম, স্ট্যাটাস, আইপি অ্যাড্রেস, ইত্যাদি)।

3. নেটওয়ার্ক অ্যাডাপ্টারের আইপি অ্যাড্রেস কনফিগার করা

# স্ট্যাটিক আইপি অ্যাড্রেস কনফিগার করা
New-NetIPAddress -InterfaceAlias "Ethernet" -IPAddress "192.168.1.10" -PrefixLength 24 -DefaultGateway "192.168.1.1"

এটি "Ethernet" নেটওয়ার্ক অ্যাডাপ্টারে "192.168.1.10" আইপি অ্যাড্রেস এবং "192.168.1.1" ডিফল্ট গেটওয়ে সেট করবে।

4. DNS সার্ভার কনফিগার করা

# DNS সার্ভার কনফিগার করা
Set-DnsClientServerAddress -InterfaceAlias "Ethernet" -ServerAddresses "8.8.8.8", "8.8.4.4"

এটি "Ethernet" নেটওয়ার্ক অ্যাডাপ্টারের জন্য DNS সার্ভার এড্রেস হিসেবে Google DNS (8.8.8.8 এবং 8.8.4.4) সেট করবে।

5. নেটওয়ার্ক অ্যাডাপ্টারের IP কনফিগারেশন দেখতে

# নেটওয়ার্ক অ্যাডাপ্টারের আইপি কনফিগারেশন দেখতে
Get-NetIPAddress -InterfaceAlias "Ethernet"

এটি "Ethernet" নেটওয়ার্ক অ্যাডাপ্টারের আইপি কনফিগারেশন দেখাবে।

6. IP রিভোকেশন বা DHCP কনফিগারেশন

# DHCP সেটিংস এনাবল করা
Set-NetIPInterface -InterfaceAlias "Ethernet" -Dhcp Enabled

# DHCP সেটিংস ডিজেবল করা
Set-NetIPInterface -InterfaceAlias "Ethernet" -Dhcp Disabled

এটি "Ethernet" নেটওয়ার্ক অ্যাডাপ্টারের জন্য DHCP এনাবল বা ডিজেবল করবে।


Network Configuration এর সেরা প্র্যাকটিস

  1. Security: নিশ্চিত করুন যে আপনার ফায়ারওয়াল রুল সঠিকভাবে কনফিগার করা হয়েছে। শুধুমাত্র প্রয়োজনীয় পোর্ট এবং অ্যাড্রেসগুলো খোলা রাখা উচিত।
  2. Monitoring: নিয়মিত ফায়ারওয়াল লগ চেক করা এবং অ্যাডাপ্টার স্ট্যাটাস পর্যবেক্ষণ করা গুরুত্বপূর্ণ।
  3. Automation: PowerShell স্ক্রিপ্ট ব্যবহার করে নেটওয়ার্ক কনফিগারেশন অটোমেট করা যেতে পারে, বিশেষ করে বড় স্কেল নেটওয়ার্কে।

সারাংশ

PowerShell ব্যবহার করে Firewall Configuration এবং Network Adapter Management অত্যন্ত সহজ এবং কার্যকরী। আপনি NetAdapter এবং NetFirewallRule কমান্ড ব্যবহার করে নেটওয়ার্ক অ্যাডাপ্টার এবং ফায়ারওয়াল রুল কনফিগার করতে পারেন। এটি সিস্টেম প্রশাসকদের জন্য অত্যন্ত সহায়ক, কারণ এটি দ্রুত এবং স্বয়ংক্রিয়ভাবে নেটওয়ার্ক সেটিংস পরিচালনা করতে সক্ষম।

Content added By

Remote Desktop Configuration এবং Security Management

143
143

PowerShell ব্যবহার করে আপনি Windows সিস্টেমে Remote Desktop (RDP) কনফিগার এবং নিরাপত্তা ব্যবস্থাপনা করতে পারেন। এটি খুবই উপকারী, কারণ এটি ব্যবহারকারীদের দূর থেকে সিস্টেম অ্যাক্সেসের জন্য একটি কার্যকরী এবং নিরাপদ উপায় সরবরাহ করে। নিচে PowerShell দিয়ে Remote Desktop কনফিগার এবং নিরাপত্তা ম্যানেজমেন্টের বিভিন্ন দিক আলোচনা করা হলো।


Remote Desktop Configuration

PowerShell দিয়ে Remote Desktop সক্রিয় করতে এবং কনফিগার করতে Set-ItemProperty এবং Enable-NetFirewallRule কমান্ড ব্যবহার করা হয়। প্রথমে আপনি Remote Desktop-এর সেটিংস পরিবর্তন করবেন এবং তারপর প্রয়োজনীয় ফায়ারওয়াল রুলস সক্ষম করবেন।

Remote Desktop সক্রিয় করা:

# Remote Desktop সক্রিয় করা
Set-ItemProperty -Path "HKLM:\System\CurrentControlSet\Control\Terminal Server" -Name "fDenyTSConnections" -Value 0

এই কমান্ডটি Remote Desktop সক্রিয় করবে। যেখানে:

  • fDenyTSConnections রেজিস্ট্রি ভ্যালুটি 0 করলে Remote Desktop সক্রিয় হবে এবং 1 করলে এটি বন্ধ থাকবে।

Remote Desktop-এর জন্য ফায়ারওয়াল রুলস সক্ষম করা:

# Remote Desktop ফায়ারওয়াল রুলস সক্ষম করা
Enable-NetFirewallRule -DisplayGroup "Remote Desktop"

এটি Remote Desktop সংযোগের জন্য Windows Firewall-এর প্রয়োজনীয় রুলস সক্রিয় করবে, যাতে আপনি সিস্টেমে দূরবর্তীভাবে সংযুক্ত হতে পারেন।


Remote Desktop Access Control

PowerShell দিয়ে আপনি Remote Desktop অ্যাক্সেসের জন্য ইউজার অ্যাকাউন্ট কনফিগার করতে পারেন। Add-LocalGroupMember কমান্ডটি ব্যবহার করে আপনি কোনো ইউজারকে Remote Desktop Users গ্রুপে যোগ করতে পারেন।

Remote Desktop Users গ্রুপে ইউজার যোগ করা:

# ইউজারকে Remote Desktop Users গ্রুপে যোগ করা
Add-LocalGroupMember -Group "Remote Desktop Users" -Member "username"

এটি "username" ইউজারকে Remote Desktop Users গ্রুপে যোগ করবে, যার মাধ্যমে তিনি RDP ব্যবহার করতে পারবেন।

Remote Desktop Users গ্রুপ থেকে ইউজার সরানো:

# ইউজারকে Remote Desktop Users গ্রুপ থেকে সরানো
Remove-LocalGroupMember -Group "Remote Desktop Users" -Member "username"

এটি "username" ইউজারকে Remote Desktop Users গ্রুপ থেকে সরিয়ে দেবে, ফলে তিনি RDP ব্যবহার করতে পারবেন না।


Remote Desktop Security Management

Remote Desktop ব্যবহার করার সময় নিরাপত্তা নিশ্চিত করা অত্যন্ত গুরুত্বপূর্ণ। আপনি PowerShell-এর মাধ্যমে বিভিন্ন নিরাপত্তা কনফিগারেশন এবং পলিসি প্রয়োগ করতে পারেন।

Network Level Authentication (NLA) সক্রিয় করা:

Network Level Authentication (NLA) সক্রিয় করা অত্যন্ত গুরুত্বপূর্ণ, কারণ এটি সংযোগের আগে ব্যবহারকারীর পরিচয় যাচাই করে, যা নিরাপত্তা বাড়ায়।

# NLA সক্রিয় করা
Set-ItemProperty -Path "HKLM:\System\CurrentControlSet\Control\Terminal Server" -Name "UserAuthentication" -Value 1

এটি NLA সক্রিয় করবে, যার মাধ্যমে সংযোগ করার জন্য ব্যবহারকারীর প্রমাণীকরণ করা হবে।

Remote Desktop Session Timeout কনফিগার করা:

# Remote Desktop session timeout কনফিগার করা
Set-ItemProperty -Path "HKLM:\System\CurrentControlSet\Control\Terminal Server" -Name "IdleTimeLimit" -Value 600

এটি Remote Desktop সেশনের জন্য একটি টাইমআউট সেট করবে। এখানে 600 সেকেন্ড বা 10 মিনিট টাইমআউটের জন্য নির্ধারিত।

Remote Desktop Session Encryption সেট করা:

# Remote Desktop session encryption সেট করা
Set-ItemProperty -Path "HKLM:\System\CurrentControlSet\Control\Terminal Server" -Name "SecurityLayer" -Value 1

এটি Remote Desktop সেশনের জন্য এনক্রিপশন সক্ষম করবে, যা সংযোগের নিরাপত্তা বৃদ্ধি করবে।


Remote Desktop Audit Enable করা

Remote Desktop সংক্রান্ত লগ এবং অডিটিং চালু করা অত্যন্ত গুরুত্বপূর্ণ, যাতে আপনি জানেন কখন এবং কে সিস্টেমে লগ ইন করছে। PowerShell দিয়ে আপনি Audit Policy কনফিগার করতে পারেন।

Remote Desktop Access Log Enable করা:

# Remote Desktop Access Audit Enable করা
auditpol /set /subcategory:"Logon/Logoff" /success:enable /failure:enable

এই কমান্ডটি Logon/Logoff সাবক্যাটাগরি জন্য সাফল্য এবং ব্যর্থতার অডিটিং সক্ষম করবে, যার মাধ্যমে আপনি Remote Desktop অ্যাক্সেসের লগ রাখতে পারবেন।


Remote Desktop এর জন্য নিরাপত্তা পরামর্শ

  1. Strong Password Policy: Remote Desktop অ্যাক্সেসের জন্য শক্তিশালী পাসওয়ার্ড ব্যবহার করুন এবং পাসওয়ার্ড কমপ্লেক্সিটি প্রয়োগ করুন।
  2. Firewall Configuration: নির্দিষ্ট IP রেঞ্জ বা সাবনেট থেকে Remote Desktop অ্যাক্সেস সীমাবদ্ধ করুন।
  3. Multi-Factor Authentication (MFA): Remote Desktop-এ MFA প্রয়োগ করলে নিরাপত্তা আরও শক্তিশালী হবে।
  4. Remote Desktop Gateway ব্যবহার করুন: যদি সম্ভব হয়, Remote Desktop Gateway ব্যবহার করুন, যা RDP সংযোগকে একটি নিরাপদ টানেলের মধ্যে এনক্রিপ্ট করে।

সারাংশ

PowerShell দিয়ে Remote Desktop কনফিগার এবং নিরাপত্তা পরিচালনা করা সহজ এবং দ্রুত হতে পারে। আপনি Remote Desktop সক্রিয় করতে, ব্যবহারকারী অ্যাক্সেস কনফিগার করতে, এবং নিরাপত্তা সেটিংস প্রয়োগ করতে Set-ItemProperty, Add-LocalGroupMember, Enable-NetFirewallRule ইত্যাদি কমান্ড ব্যবহার করতে পারেন। এই কনফিগারেশনগুলো দূরবর্তী অ্যাক্সেসের নিরাপত্তা নিশ্চিত করতে সহায়তা করবে।

Content added By

Network Drive Mapping এবং Shared Folder Access

139
139

PowerShell ব্যবহার করে আপনি সহজেই network drives ম্যাপ (mapping) করতে পারেন এবং shared folders-এ অ্যাক্সেস (access) করতে পারেন। এটি Windows-এ ফাইল শেয়ারিং এবং নেটওয়ার্কের মধ্যে ফাইল ট্রান্সফারের জন্য খুবই উপকারী।


Network Drive Mapping (নেটওয়ার্ক ড্রাইভ ম্যাপিং)

নেটওয়ার্ক ড্রাইভ ম্যাপিং করা হলে, আপনি একটি রিমোট ফোল্ডার বা ড্রাইভকে আপনার সিস্টেমে একটি নতুন ড্রাইভ লেটার হিসেবে সংযুক্ত (map) করতে পারেন। PowerShell-এ New-PSDrive এবং net use কমান্ড ব্যবহার করে এটি করা যায়।

PowerShell দিয়ে Network Drive Mapping:

New-PSDrive -Name "Z" -PSProvider FileSystem -Root "\\server\sharedFolder" -Persist

এখানে:

  • -Name: ম্যাপ করা ড্রাইভের নাম (এটি আপনার সিস্টেমে প্রদর্শিত হবে, যেমন "Z" ড্রাইভ)।
  • -PSProvider FileSystem: ফাইল সিস্টেম প্রোভাইডার ব্যবহার করা হচ্ছে।
  • -Root: শেয়ার করা ফোল্ডারের UNC পাথ। উদাহরণস্বরূপ, \\server\sharedFolder
  • -Persist: এটি নিশ্চিত করে যে ড্রাইভটি সিস্টেম রিবুট হলে টিকে থাকবে।

Network Drive-এ ফাইল এক্সপ্লোর করা:

আপনি ম্যাপ করা ড্রাইভে যেতে চাইলে:

Set-Location -Path "Z:\"

এটি আপনাকে "Z" ড্রাইভে নিয়ে যাবে।


Network Drive Unmapping (নেটওয়ার্ক ড্রাইভ আনম্যাপিং)

নেটওয়ার্ক ড্রাইভ আনম্যাপ করতে হলে, আপনি Remove-PSDrive কমান্ড ব্যবহার করতে পারেন:

Remove-PSDrive -Name "Z"

এটি "Z" ড্রাইভটি আনম্যাপ করবে।


Shared Folder Access (শেয়ারড ফোল্ডার অ্যাক্সেস)

শেয়ারড ফোল্ডারে অ্যাক্সেস করার জন্য, আপনি নেটওয়ার্কের শেয়ার করা ফোল্ডারের UNC পাথ ব্যবহার করতে পারেন এবং ফাইল সিস্টেমের উপর কাজ করতে পারেন। PowerShell-এ New-PSDrive কমান্ডের মাধ্যমে শেয়ারড ফোল্ডার মাউন্ট করতে পারবেন এবং ফাইলগুলি এক্সপ্লোর করতে পারবেন।

Shared Folder মাউন্ট করা:

New-PSDrive -Name "S" -PSProvider FileSystem -Root "\\server\sharedFolder" -Persist

এটি "S" ড্রাইভে \\server\sharedFolder শেয়ারড ফোল্ডারটি মাউন্ট করবে।

Shared Folder-এ ফাইল তৈরি করা:

আপনি শেয়ারড ফোল্ডারে ফাইল তৈরি করতে পারেন:

New-Item -Path "S:\newfile.txt" -ItemType "File"

এটি "S" ড্রাইভের মধ্যে "newfile.txt" নামের একটি নতুন ফাইল তৈরি করবে।

Shared Folder-এ ফাইল পড়া:

Get-Content -Path "S:\newfile.txt"

এটি "S" ড্রাইভের "newfile.txt" ফাইলটির কনটেন্ট পড়বে।

Shared Folder-এ ফাইল মুছে ফেলা:

Remove-Item -Path "S:\newfile.txt"

এটি "S" ড্রাইভের "newfile.txt" ফাইলটি মুছে ফেলবে।


Authentication দিয়ে Shared Folder Access

যদি আপনার শেয়ারড ফোল্ডারের জন্য authentication প্রয়োজন হয়, তবে net use কমান্ড ব্যবহার করে ইউজারনেম এবং পাসওয়ার্ড দিয়ে অ্যাক্সেস পাওয়া যায়।

Shared Folder Access with Credentials:

net use Z: \\server\sharedFolder /user:DomainName\Username Password

এটি "Z:" ড্রাইভে \\server\sharedFolder শেয়ারড ফোল্ডার মাউন্ট করবে এবং DomainName\Username এবং Password দিয়ে প্রমাণীকরণ করবে।

Shared Folder Unmount with Credentials:

net use Z: /delete

এটি "Z:" ড্রাইভটি আনম্যাপ করবে।


সারাংশ

PowerShell-এ New-PSDrive এবং net use কমান্ড ব্যবহার করে আপনি নেটওয়ার্ক ড্রাইভ ম্যাপ করতে পারেন এবং শেয়ারড ফোল্ডার অ্যাক্সেস করতে পারেন। আপনি শেয়ারড ফোল্ডারে ফাইল তৈরি, পড়া, এবং মুছে ফেলতে পারেন, এবং -Persist প্যারামিটার ব্যবহার করে ড্রাইভটিকে সিস্টেম রিবুটের পরেও রাখতে পারেন।

Content added By
Promotion